package consume.config;

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.HeadersExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author : xiaohong
 * @date : 2021/4/11 15:29
 * 参数模式配置
 */

@Configuration
public class HeadersConfig {

    // 声明注册headers模式的交换机
    @Bean
    public HeadersExchange headersExchange(){
        // 交换机名称 是否持久化 是否自动删除
        // 持久化： 服务器重启后该交换机是否还存在
        // 自动删除： 完成任务后是否自动删除该交换机
        return new HeadersExchange("headers_exchange",true,false);
    }

    // 声明队列headers1 headers2 headers3

    // 参数1 声明队列
    // 参数2 durable：持久化 erlang 数据库，有专门的表去保存我们的队列声明
    // 参数3 exclusive：排外 当前定义的队列connection中的channel是共享的，其他的connection是访问不到的
    // 参数4 autoDelete：自动删除 当前最后一个consumer断开之后，autoDelete队列
    // 参数5 agruments：rabbitmq的扩展

    @Bean
    public Queue headers1() {
        return new Queue("headers1",true);
    }

    @Bean
    public Queue headers2() {
        return new Queue("headers2",true);
    }

    @Bean
    public Queue headers3() {
        return new Queue("headers3",true);
    }


    //完成队列和交换机的绑定关系

    @Bean
    public Binding headers1Binding(){
        return BindingBuilder.bind(headers1()).to(headersExchange()).where("header1").matches("xiaohong");
    }

    @Bean
    public Binding headers2Binding(){
        return BindingBuilder.bind(headers2()).to(headersExchange()).where("header2").matches("xiaohong");
    }

    @Bean
    public Binding headers3Binding(){
        return BindingBuilder.bind(headers3()).to(headersExchange()).where("header3").matches("xiaohong");
    }


}
